# PATENT ABSTRACTS OF JAPAN

(11)Publication number:

10-222995

(43)Date of publication of application: 21.08.1998

(51)Int.CI.

G11C 16/06 G11C 16/04 G11C 29/00

(21)Application number: 09-055769

(71)Applicant: SONY CORP

(22)Date of filing:

11.03.1997

(72)Inventor: ARASE KENSHIROU

NODA MASANORI

SUGIYAMA HISANOBU NAIKI TADAHACHI

(30)Priority

Priority number: 08323011

Priority date: 03.12.1996

04.12.1996

Priority country: JP

JP

## (54) SEMICONDUCTOR NON-VOLATILE STORAGE

08324293

## (57)Abstract:

PROBLEM TO BE SOLVED: To achieve a semiconductor non-volatile storage that is capable of carrying out highspeed data programming.

SOLUTION: Error correction means 20 and 30 are provided for correcting error bits when reading of page data in word line units is conducted and a specified number of error bits or less exist in page read-out data. Then, in a page program in work line units, a specific number of program/verification operations are repeated, the number of program non-completion memory cells is counted by a count circuit 40 when the program noncompletion memory cells exist. Then, when the number is within a specific number of error bits or less as in the above for achieving error correction, the data program is completed while leaving the program non-completed memory cells and the error bits are rescued by an error correction means, thus achieving a data program speedily without causing a speed to be controlled by a memory cell with an extremely slow program that exists only rarely.



## **LEGAL STATUS**

[Date of request for examination]

[Date of sending the examiner's decision of rejection]

[Kind of final disposal of application other than the examiner's decision of rejection or application converted registration]

[Date of final disposal for application]

[Patent number]

[Date of registration]

[Number of appeal against examiner's decision of rejection]

[Date of requesting appeal against examiner's decision of rejection]

[Date of extinction of right]

Copyright (C); 1998,2003 Japan Patent Office

### (19)日本国特許庁 (JP)

# (12) 公開特許公報(A)

(11)特許出願公開番号

# 特開平10-222995

(43)公開日 平成10年(1998) 8月21日

| (51) Int.Cl. <sup>6</sup> |       | 識別記号  | <b>F</b> I |       |      |  |
|---------------------------|-------|-------|------------|-------|------|--|
| G11C                      | 16/06 |       | G11C 1     | 17/00 | 639C |  |
|                           | 16/04 |       | 2          | 29/00 | 631Q |  |
|                           | 29/00 | 6 3 1 |            | 17/00 | 622E |  |

## 審査請求 未請求 請求項の数15 OL (全 15 頁)

| (21)出願番号      | 特顯平9-55769         | (71)出顧人   | 000002185                |
|---------------|--------------------|-----------|--------------------------|
| (00) (I) FF I |                    |           | ソニー株式会社                  |
| (22)出顧日       | 平成9年(1997)3月11日    | (72)発明者   | 東京都品川区北品川6丁目7番35号 荒瀬 謙士朗 |
| (31)優先権主張番号   | <b>特願平8-323011</b> | (12)75914 |                          |
|               |                    |           | 東京都品川区北品川6丁目7番35号 ソニ     |
| (32)優先日       | 平 8 (1996)12月 3 日  |           | 一株式会社内                   |
| (33)優先権主張国    | 日本 (JP)            | (72)発明者   | 野田 昌敬                    |
| (31)優先権主張番号   | 特願平8-324293        |           | 東京都品川区北品川6丁目7番35号 ソニ     |
| (32)優先日       | 平8 (1996)12月4日     |           | 一株式会社内                   |
| (33)優先権主張国    | 日本(JP)             | (72)発明者   | 杉山 寿伸                    |
|               |                    | ·         | 東京都品川区北品川6丁目7番35号 ソニ     |
|               |                    |           | 一株式会社内                   |
|               |                    | (74)代理人   | 弁理士 佐藤 隆久                |
|               |                    |           | 最終頁に続く                   |

# (54) 【発明の名称】 半導体不揮発性記憶装置

### (57)【要約】

【課題】高速なデータプログラムが可能な半導体不揮発性記憶装置を実現する。

【解決手段】ワード線単位でページデータの読み出しを行い、ページ読み出しデータ内に所定個数以内のエラービットが存在する場合に、エラービットを訂正するページプログラムにおいて、所定回数のプログラムにおいて、所定回数のプログラムにおいて、所後にプログラム未終了メーファイ動作を繰り返し行った後にプログラム未終了メーフャルが存在する場合に、当該個数をカウント回路40で計数し、当該個数がエラー記で可能な前記所定個数以内のエラービットである場合に、プログラムを終了メモリセルを残したままラービットを前記エラー訂正手段により救済する。したがって、ごくまれに存する非常にプログラムの遅いメモリセルに律速されることなく、高速にデータプログラムが可能となる。



#### 【特許請求の範囲】

【請求項1】 電気的にデータの処理が行われるメモリセルがマトリクス配置された半導体不揮発性記憶装置であって、

複数ビットデータ内に所定個数以内のエラービットが存 在する場合に当該エラービットを訂正するエラー訂正手 段と、

前記複数ビットデータを単位としたデータの処理を当該 複数単位のメモリセルに対して行い、データの処理後に 当該データ処理未終了メモリセルの個数を計数する手段 と、

前記データ処理未終了メモリセルの個数が前記所定個数以内のエラービットである場合に、当該データ処理未終了メモリセルを残したままデータの処理を終了し、当該エラービットを前記エラー訂正手段に救済させる手段とを備えた半導体不揮発性記憶装置。

【請求項2】 電気的にデータのプログラムが行われる メモリセルがマトリクス配置された半導体不揮発性記憶 装置であって、

複数ビットデータを単位としてデータの読み出しを行い、当該複数ビットデータ内に所定個数以内のエラービットが存在する場合に当該エラービットを訂正するエラー訂正手段と、

前記複数ビットデータを単位としたデータプログラムを 当該複数単位のメモリセルに対して行い、データプログ ラム後にプログラム未終了メモリセルの個数を計数する 手段と、

前記プログラム未終了メモリセルの個数が前記所定個数以内のエラービットである場合に、当該プログラム未終了メモリセルを残したままデータプログラムを終了し、当該エラービットを前記エラー訂正手段に救済させる手段とを備えた半導体不揮発性記憶装置。

【請求項3】 セクタ単位のページプログラムデータを各ビット線毎に設けられたデータラッチ回路に転送し、当該データに従って選択されたセクタのメモリセル一括に電気的にデータプログラムが行われるメモリセルがマトリクス配置された半導体不揮発性記憶装置であって、選択されたセクタのメモリセル単位でページデータの読み出しを行い、当該ページ読み出しデータ内に所定個数以内のエラービットが存在する場合に当該エラービットを訂正するエラー訂正手段と、

前記ページプログラムデータに従ったデータプログラムがベリファイ読み出し動作を介して複数回のプログラム動作を繰り返し行うことによりなされ、各プログラム動作毎にプログラム未終了メモリセルが存在するか否かを検知する手段と、

所定回数のプログラム動作を繰り返し行った後にプログラム未終了メモリセルが存在する場合に、当該プログラム未終了メモリセルの個数を計数する手段と、

前記プログラム未終了メモリセルの個数が前記所定個数

以内のエラービットである場合に、当該プログラム未終 アメモリセルを残したままデータプログラムを終了し、 当該エラービットを前記エラー訂正手段に救済させる手 段とを備えた半導体不揮発性記憶装置。

【請求項4】 上記セクタ単位はワード線単位である請求項3記載の半導体不揮発性記憶装置。

【請求項5】 前記エラー訂正手段は、プログラムすべき正規データよりエラー検査コードを発生する手段と、前記正規データを記録するための正規メモリアレイ部と前記エラー検査コードを記録するためのパリティメモリアレイ部とから構成されたメモリアレイと、

前記正規データとエラー検査コードにより合成されたページプログラムデータを前記メモリアレイにページプログラムする手段と、

前記ページプログラムデータのデータ読み出し時に、読み出した正規データとエラー検査コードによりデータプログラム時のエラービットを訂正する手段とを備えた請求項3記載の半導体不揮発性記憶装置。

【請求項6】 前記プログラム未終了メモリセルの検知 手段は、各プログラム動作後のベリファイ読み出し動作 毎に、プログラムが終了したメモリセルの接続されたデ ータラッチ回路にラッチされているデータを順次反転さ せて再プログラムデータを自動設定する手段と、

前記再プログラムデータの自動設定後に、プログラム未終了のデータがラッチされているデータラッチ回路が少なくとも1個以上存在するか否かを検出する終点検出手段とを備えた請求項3記載の半導体不揮発性記憶装置。

【請求項7】 前記プログラム未終了メモリセルの計数 手段は、一定のクロックパルスに同期したカラムデコー ダの動作によりページ読み出しし、当該ページ読み出し データを順次計数回路にシフト転送してプログラム未終 了のデータの個数をカウントする請求項3記載の半導体 不揮発性記憶装置。

【請求項8】 前記メモリセルがマトリクス配置されたメモリアレイは、複数のメモリセルが直列接続されたNAND型構造をなす請求項3記載の半導体不揮発性記憶装置。

【請求項9】 前記メモリセルがマトリクス配置された メモリアレイは、NOR型構造をなし、

かつ主ビット線が作動的接続手段を介して複数の副ビット線に階層化されている請求項3記載の半導体不揮発性 記憶装置。

【請求項10】 電気的にデータの消去およびプログラムを行うことによりデータの書き換えが可能なメモリセルがマトリクス配置された半導体不揮発性記憶装置であって.

複数ビットデータを単位としてデータの読み出しを行い、当該複数ビットデータ単位内に所定個数以内のエラービットが存在する場合に当該エラービットを訂正する エラー訂正手段と、 少なくとも1単位以上の前記複数ビットデータ単位のメモリセルに対してデータ消去を行い、データ消去後に当該各複数ビットデータ単位内の消去未終了メモリセルの個数を計数する手段と、

前記消去未終了メモリセルの個数が前記所定個数以内の エラービットである場合に、当該消去未終了メモリセル を残したままデータプログラムを行い、当該エラービッ トをデータ読み出し時に前記エラー訂正手段に救済させ る手段とを備えた半導体不揮発性記憶装置。

【請求項11】 電気的にデータの消去およびプログラムを行うことによりデータの書き換えが可能なメモリセルがマトリクス配置された半導体不揮発性記憶装置であって、

複数ビットデータを単位としてデータの読み出しを行い、当該複数ビットデータ単位内に所定個数以内のエラービットが存在する場合に当該エラービットを訂正する エラー訂正手段と、

少なくとも1単位以上の前記複数ビットデータ単位のメモリセルに対するデータ消去を、ベリファイ読み出し動作を介して複数回の消去電圧パルスを繰り返し印加して行い、各消去動作毎に消去未終了メモリセルが存在するか否かを検知する手段と、

所定回数の消去動作を繰り返し行った後に消去未終了メ モリセルが存在する場合に、各複数ビットデータ単位内 の消去未終了メモリセルの個数を計数する手段と、

前記消去未終了メモリセルの個数が前記所定個数以内のエラービットである場合に、当該消去未終了メモリセルを残したままデータプログラムを行い、当該エラービットをデータ読み出し時に前記エラー訂正手段に救済させる手段とを備えた半導体不揮発性記憶装置。

【請求項12】 前記エラー訂正手段は、プログラムすべき正規データよりエラー検査コードを発生する手段と、

前記正規データを記録するための正規メモリアレイ部と 前記エラー検査コードを記録するためのパリティメモリ アレイ部とから構成されたメモリアレイと、

前記正規データとエラー検査コードにより合成された前記複数ビットデータ単位のプログラムデータをデータ消去後の前記メモリアレイにプログラムする手段と、

前記複数ビットデータ単位のデータ読み出し時に、読み出した正規データとエラー検査コードによりデータプログラム時のエラービットを訂正する手段とを備えた請求項11記載の半導体不揮発性記憶装置。

【請求項13】 前記複数ビットデータ単位のメモリセルは、ワード線毎のページ単位のメモリセルであるを備えた請求項11記載の半導体不揮発性記憶装置。

【請求項14】 前記消去未終了メモリセルの計数手段は、一定のクロックパルスに同期したカラムデコーダの動作によりページ読み出しし、当該ページ読み出しデータを順次計数回路にシフト転送してプログラム未終了の

データの個数をカウントする請求項11記載の半導体不 揮発性記憶装置。

【請求項15】 前記メモリセルがマトリクス配置されたメモリアレイは、NOR型構造をなす請求項11記載の半導体不揮発性記憶装置。

#### 【発明の詳細な説明】

[0001]

【発明の属する技術分野】本発明は、電気的にデータの プログラムが可能な半導体不揮発性記憶装置に係り、特 にデータプログラムおよび消去の高速化に関するもので ある。

#### [0002]

【従来の技術】NAND型フラッシュメモリ、DINOR型フラッシュメモリ等の半導体不揮発性記憶装置においては、選択するワード線に接続されたすべてのメモリセルー括にデータプログラムが行われる。すなわち、ワード線単位でページプログラムが行われる。

【OOO3】図7(a)、図7(b)は、それぞれNA ND型、DINOR型フラッシュメモリにおける、メモ リアレイ構造を示す図である。

【0004】図7(a)は、便宜上、1本のビット線に接続されたNAND列1本に4個のメモリセルが接続された場合のNAND型フラッシュメモリアレイを示す図である。図7(a)において、BLはビット線を示し、ビット線BLに2個の選択トランジスタタST1~ST2、および4個のメモリセルMT1~MT4が直列接続されたNAND列が接続されている。選択トランジスタタST1~ST2はそれぞれ選択ゲート線SL1、SL2により制御され、またメモリセルMT1~MT4はそれぞれワード線WL1~WL4により制御される。

【0005】図7(b)は、便宜上、1本の主ビット線に接続された副ビット線1本に4個のメモリトランジスタが接続された場合のDINOR型フラッシュメモリアレイを示す図である。図7(b)において、MBLは主ビット線、SBLは副ビット線をそれぞれ示し、主ビット線MBLおよび副ビット線SBLは、選択ゲート線SLにより制御される選択トランジスタST1を介して作動的に接続される。副ビット線SBLは、4本のワード線WL1~WL4と交差し、各交差位置には4個のメモリセルMT1~MT4が配置されている。

【0006】また、NOR型フラッシュメモリ等の半導体不揮発性記憶装置においては、データの書き換えは、所定のブロック単位(たとえば64Kバイト程度)でデータの消去を行った後、当該消去ブロックのメモリセルに対してデータプログラムが行われる。

【0007】図8は、一般的なNOR型フラッシュメモリにおける、メモリアレイ構造およびデータ消去時のバイアス条件を示す図である。

【0008】図8のNOR型フラッシュメモリにおいては、便宜上、4本のワード線WL1~WL4と4本のビ

ット線BL1~BL4との格子位置にメモリセルMT1 1~MT44がマトリクス配置されている。

【0009】次に、図8のNOR型フラッシュメモリにおいて、データ消去動作について説明する。データ消去は、図8に示すように、消去ブロックメモリアレイ内のすべてのワード線WL1~WL4を接地レベル(0V)に、すべてのビット線BL1~BL4をフローティング状態とし、共通ソース線VSSに高電圧(たとえば12V)の消去電圧パルスを印加する。その結果、データプログラム時に各メモリセルに蓄積されていた電子がソース側からトンネル電流により引き抜かれて、各メモリセルのしきい値電圧Vthは、データプログラム状態の6V~7Vから消去状態の2V~3Vに遷移する。

#### [0010]

【発明が解決しようとする課題】ところで、上述したNAND型、DINOR型フラッシュメモリ等のようなワード線セクタを単位としたページプログラムを行う半導体不揮発性記憶装置においては、データのプログラムは選択ワード線に接続されたすべてのメモリセルー括にデータプログラムを行う。しかし、選択ワード線に接続された各メモリセルは、製造プロセスに起因するサイズ等のパラツキのため、それぞれプログラム速度に差が生じる。

【0011】図9は上述した各選択ワード線に接続されたメモリセル間のプログラム速度の差を示す図である。図9において、横軸はtPROG(プログラム時間)、すなわち各メモリセルのプログラム必要時間を表わしている。また、縦軸はN(メモリセル個数)、すなわち横軸tPROG(プログラム時間)に対応したメモリセル個数の分布頻度を表わしている。

【0012】図9に示すように、NAND型フラッシュメモリ等のようなワード線セクタを単位としたページプログラムを行う半導体不揮発性記憶装置においては、メモリセル間でプログラム必要時間 t PROGに分布が生じる。このようなプログラム速度のバラツキを考慮して、一般的なNAND型フラッシュメモリ等においては、プログラム時のしきい値電圧Vthの分布を狭介しなる観点から、プログラム動作がベリファイ動作をプログラム終了メモリセルから順次プログラム禁止にしてすべてのメモリセルのプログラムが終了するまで繰り返し行う、いわゆるビット毎ベリファイ動作が行われる。

【0013】ところが図9に示すように、一般的なメモリセルの場合、プログラム必要時間 t PROGは図中 t 0であるが、プロセス等のバラツキ要因から非常に長いプログラム必要時間 t PROG、たとえば図中 t 1以上を要するメモリセルがごくまれに存在する場合がある。このような場合、ごくまれに存在するプログラムの遅いメモリセルのために、上述したプログラム/ベリファイ動作の回数も、たとえば100回以上と非常に多くな

り、その結果、ページプログラムを終了するのに要する 時間も非常に長くなる。

【0014】図10は、かかる従来のNAND型フラッシュメモリ等のようなワード線セクタを単位としたページプログラムを行う半導体不揮発性記憶装置における、データプログラム時のシーケンスフローを示す図である。以下、図6のシーケンスフローについて、順を追って説明する。

【0015】ステップステップSF1でデータプログラムが開始され、最初にステップSF2でページプログラムデータがメモリアレイ内の各ビット線毎に設けられたデータラッチ回路に転送される。次に、ステップSF3でプログラムベリファイ回数Kが0にリセットされ、プログラムパルスを印加するプログラム動作(ステップSF4)、およびベリファイ読み出し後に再プログラムがベリファイ読み出し動作(ステップSF5)が連続して行われる。次に、ステップSF6ですべてのメモリセルのプログラムが終了したかどうかの終点検出が、再プログラムデータ内に少なくとも1個以上のプログラム未終了メモリセルが残っているか否かを調べることにより行われる。

【0016】その結果、全ビットプログラム終了の終点検出ができた場合には、データプログラムを完了する(ステップSF9)。一方、全ビットプログラム終了の終点検出ができなかった場合には、さらにプログラムベリファイ回数Kがインクリメントされ(ステップSF7)、Kが予め設定された所定回数k0(たとえば100回程度)未満であるかどうかが調べられる(ステップSF8)。そしてKがk0未満である場合には、上述したステップSF4~ステップSF8のシーケンスフローが繰り返し行われ、Kがk0に到達した時点でデータプログラム失敗と判断される(ステップSF10)。

【0017】この所定のプログラムベリファイ回数KOは、ごくまれに存在するプログラムの遅いメモリセルのために、従来のNAND型フラッシュメモリ等の場合たとえば100回以上と非常に多くなり、その結果、ページプログラムを終了するのに要する時間も非常に長くなっていた。

【0018】また、上述したNOR型フラッシュメモリ等のような半導体不揮発性記憶装置においては、データの書き換えは、所定のブロック単位(たとえば64Kバイト程度)でデータ消去を行った後、当該ブロック単位でデータプログラムを行う。しかし、消去ブロック単位内の各メモリセルは、製造プロセスに起因するサイズ等のパラツキのため、それぞれ消去速度に差が生じる。

【0019】図11は上述した消去ブロック内のメモリセル間の消去速度の差を示す図である。図11において、横軸はterase(消去時間)、すなわち各メモリセルの消去必要時間を表わしている。また、縦軸はN(メモリセル個数)、すなわち横軸terase(消去

時間)に対応したメモリセル個数の分布頻度を表わしている。

【0020】図11に示すように、NOR型フラッシュメモリ等のような所定のブロック単位でデータ消去を行う半導体不揮発性記憶装置においては、メモリセル間で消去必要時間teraseに分布が生じる。このような消去速度のパラツキを考慮して、一般的なNOR型フラッシュメモリにおいては、消去動作がベリファイ動作を介して行われ、かつ当該消去/ベリファイ動作を消去ブロック内のすべてのメモリセルのデータ消去が終了するまで繰り返し行われる。

【0021】ところが図11に示すように、一般的なメモリセルの場合、消去必要時間teraseは図中t0であるが、プロセス等のバラツキ要因から非常に長い消去必要時間terase、たとえば図中t1以上を要けるメモリセルがごくまれに存在する場合がある。これに存在する消去の遅いメモリセルがごくまれに存在する消去の遅いメモリセルがごくまれに存在する消去の遅いとも、上述した消去/ベリファイ動作の回数も、たそのたば100回~100回以上と非常に多くまりによびはデータの書き換えに要する時間も長くないる。さらに、ごくまれに存在する消去の遅いよに多くないのために消去/ベリファイ動作の回数が非常に多ないのために消去/ベリファイ動作の回数が非常に多くないのために消去/ベリファイ動作の回数が非常に多まとして、消去の速いメモリセルがデプレーション状態(Vthく〇)となって、誤動作の原因となる。

【0022】図12は、かかる従来のNOR型フラッシュメモリ等のような所定のブロック単位でデータの書き換えを行う半導体不揮発性記憶装置における、データ消去およびその後のデータプログラム時のシーケンスフローを示す図である。以下、図12のシーケンスフローについて、順を追って説明する。

【0023】ステップSF21でデータ消去が開始され、ステップSF22で消去ベリファイ回数Kを最初の1に設定して消去パルスを印加する消去動作(ステップSF23)、およびベリファイ読み出し動作(ステップSF24)が連続して行われる。ステップSF24のベリファイ読み出し動作の結果、ブロック内のすべてのメモリセルの消去終了の終点検出ができた場合には(ステップSF25)、データ消去を完了して、ステップSF101のデータプログラム動作が開始される。

【0024】一方、ステップSF24のベリファイ読み出し動作の結果、ブロック内のすべてのメモリセルの消去終了の終点検出ができなかった場合には(ステップSF25)、ステップSF26において、消去ベリファイ回数Kがあらかじめ設定された所定回数K0(たとえば100~1000回程度)未満であるか否かが調べられる。その結果、消去ベリファイ回数Kが設定回数K0未満である場合には、さらに消去ベリファイ回数Kがインクリメントされて(ステップSF27)、上述したステ

ップSF23~SF27のシーケンスフローが繰り返し行われる。そして、消去ベリファイ回数Kが設定回数K0に到達した時点でデータ消去失敗と判断される(ステップSF28)。

【0025】次に、ブロック内のすべてのメモリセルの消去終了の終点検出ができた場合には、引き続いてデータプログラムが開始される。まず、ステップSF101でメモリセルのアドレス番地ArーNOを最初の1に設定して、当該メモリセルに対してデータ内容に応じてアータプログラムが行われ(ステップSF102)。その結果、これでは、ステップSF103)。その結果、これでは、ステップSF104)、上述したステップSF104)、ステップSF104)、ステップSF104)、ステップSF104)、ステップSF105)。

【0026】上述したシーケンスフローにおいて、所定の消去ベリファイ回数K0は、ごくまれに存在する消去の遅いメモリセルのために、従来のNOR型フラッシュメモリ等の場合たとえば100回~1000回程度と非常に多くなり、その結果、消去動作を終了するのに要する時間も非常に長くなり、ひいてはデータの書き換えに要する時間も長くなっていた。さらには、上記消去の遅いメモリセルのために消去の速いメモリセルが過剰消去されて、誤動作の原因となっていた。

【0027】本発明は、かかる事情に鑑みてなされたものであり、その目的は、データプログラムおよびデータ消去を高速に行うことができ、データの書き換えを高速に行うことが可能で、さらには過剰消去メモリセルの発生を防止でき、信頼性の向上を図れる半導体不揮発性記憶装置を提供することにある。

#### [0028]

【課題を解決するための手段】上記目的を達成するため、本発明は、電気的にデータの処理が行われるメモリセルがマトリクス配置された半導体不揮発性記憶装置であって、複数ビットデータ内に所定個数以内のエラービットが存在する場合に当該エラービットを訂正するエラー訂正手段と、前記複数ビットデータを単位としたデータの処理を当該複数単位のメモリセルに対して行いの個理を当該データ処理未終了メモリセルの個数が前記所定個数以内のエラービットである場合に、当該データ処理未終了メモリセルを残したままデータの処理を終了し、当該エラービットを前記エラー訂正手段に救済させる手段とを備えている。

【0029】また、本発明は、電気的にデータのプログラムが行われるメモリセルがマトリクス配置された半導

体不揮発性記憶装置であって、複数ビットデータを単位としてデータの読み出しを行い、当該複数ビットデータの 内に所定個数以内のエラービットが存在する場合に当該エラービットを訂正するエラー訂正手段と、前記複数ビットデータを単位としたデータプログラムを当該複数ビットデータを単位としたデータプログラムを当該複数に立て行い、データプログラムを当びである場合に、当該プログラム未終了メモリセルの個数が前記所定個数とである場合に、当該プログラムを終了したままデータプログラムを終了したままデータプログラムを終了とを備えている。

【0030】また、本発明は、セクタ単位のページプロ グラムデータを各ビット線毎に設けられたデータラッチ 回路に転送し、当該データに従って選択されたセクタの メモリセル一括に電気的にデータプログラムが行われる メモリセルがマトリクス配置された半導体不揮発性記憶 装置であって、選択されたセクタのメモリセル単位でペ ージデータの読み出しを行い、当該ページ読み出しデー タ内に所定個数以内のエラービットが存在する場合に当 該エラービットを訂正するエラ―訂正手段と、前記ペー ジプログラムデータに従ったデータプログラムがベリフ ァイ読み出し動作を介して複数回のプログラム動作を繰 り返し行うことによりなされ、各プログラム動作毎にプ ログラム未終了メモリセルが存在するか否かを検知する 手段と、所定回数のプログラム動作を繰り返し行った後 にプログラム未終了メモリセルが存在する場合に、当該 プログラム未終了メモリセルの個数を計数する手段と、 前記プログラム未終了メモリセルの個数が前記所定個数 以内のエラービットである場合に、当該プログラム未終 了メモリセルを残したままデータプログラムを終了し、 当該エラービットを前記エラー訂正手段に救済させる手 段とを備えている。

【0031】また、好適には、前記エラー訂正手段は、プログラムすべき正規データよりエラー検査コードを発生する手段と、前記正規データを記録するための正規メモリアレイ部と前記エラー検査コードを記録するためのパリティメモリアレイ部とから構成されたメモリアレイと、前記正規データとエラー検査コードにより合成されたページプログラムデータを前記メモリアレイにページプログラムする手段と、前記ページプログラムデータのデータ読み出し時に、読み出した正規データとエラー検査コードによりデータプログラム時のエラービットを訂正する手段とを備えている。

【0032】また、好適には、前記プログラム未終了メモリセルの検知手段は、各プログラム動作後のベリファイ読み出し動作毎に、プログラムが終了したメモリセルの接続されたデータラッチ回路にラッチされているデータを順次反転させて再プログラムデータを自動設定する手段と、前記再プログラムデータの自動設定後に、プロ

グラム未終了のデータがラッチされているデータラッチ 回路が少なくとも1個以上存在するか否かを検出する終 点検出手段とを備えている。

【0033】本発明の半導体不揮発性記憶装置によれば、所定回数のデータ処理、たとえばプログラム動作を繰り返し行った後にプログラム未終了メモリセルが存在しても、当該プログラム未終了メモリセルの個数がエラー訂正手段により訂正可能な所定個数以内のエラービットである場合には、プログラム未終了メモリセルを残したままデータプログラムを終了する。したがって、ごくまれに存在する非常にプログラムの遅いメモリセルに律速されることなく、高速にデータプログラムが可能となる。

【0034】また、本発明は、電気的にデータの消去およびプログラムを行うことによりデータの書き換えが可能なメモリセルがマトリクス配置された半導体不揮発性記憶装置であって、複数ビットデータを単位とし内に所定個数以内のエラービットが存在する場合に当該各でである場合に、データ単位のメモリセルに対してデータ単位内の消去未終了メモリセルの個数が前記所でした。当該消去未終了メモリセルの個数が前記所でのエラービットである場合に、当該消去未終了メモリセルを残したままデータプログラムを行い、当該に教済させる手段とを備えている。

【0035】また、本発明は、電気的にデータの消去お よびプログラムを行うことによりデータの書き換えが可 能なメモリセルがマトリクス配置された半導体不揮発性 記憶装置であって、複数ビットデータを単位としてデー タの読み出しを行い、当該複数ピットデータ単位内に所 定個数以内のエラービットが存在する場合に当該エラー ビットを訂正するエラー訂正手段と、少なくとも1単位 以上の前記複数ビットデータ単位のメモリセルに対する データ消去を、ベリファイ読み出し動作を介して複数回 の消去電圧パルスを繰り返し印加して行い、各消去動作 毎に消去未終了メモリセルが存在するか否かを検知する 手段と、所定回数の消去動作を繰り返し行った後に消去 未終了メモリセルが存在する場合に、各複数ビットデー タ単位内の消去未終了メモリセルの個数を計数する手段 と、前記消去未終了メモリセルの個数が前記所定個数以 内のエラービットである場合に、当該消去未終了メモリ セルを残したままデータプログラムを行い、当該エラー ビットをデータ読み出し時に前記エラー訂正手段に救済 させる手段とを備えている。

【0036】また、好適には、前記エラー訂正手段は、 プログラムすべき正規データよりエラー検査コードを発 生する手段と、前記正規データを記録するための正規メ モリアレイ部と前記エラー検査コードを記録するためのパリティメモリアレイ部とから構成されたメモリアレイと、前記正規データとエラー検査コードにより合成された前記複数ビットデータ単位のプログラムデータをデータ消去後の前記メモリアレイにプログラムする手段と、前記複数ビットデータ単位のデータ読み出し時に、読み出した正規データとエラー検査コードによりデータプログラム時のエラービットを訂正する手段とを備えている。

【0037】また、好適には、前記プログラム未終了メモリセルの計数手段は、一定のクロックパルスに同期したカラムデコーダの動作によりページ読み出しし、当該ページ読み出しデータを順次計数回路にシフト転送してプログラム未終了のデータの個数をカウントする。

【0038】本発明の半導体不揮発性記憶装置によれば、所定回数の消去動作を繰り返し行った後に消去未終アメモリセルが存在しても、当該消去未終アメモリセルの個数がエラー訂正手段により訂正可能な所定個数以内のエラービットである場合には、消去未終アメモリセルを残したままデータプログラムが行われる。したがって、ごくまれに存在する非常に消去の遅いメモリセルにに律速されることなく、高速にデータプログラムが可能となり、ひいてはデータの書き換えを高速に行うことができる。さらには、消去の速いメモリセルが過剰消去されることを防止でき、信頼性の高い半導体不揮発性記憶装置を実現することができる。

[0039]

【発明の実施の形態】

#### <u>第1 実施例</u>

図1は、本発明に係る半導体不揮発性記憶装置、たとえばNAND型フラッシュメモリの具体的な構成例を示す 図である。

【0040】図1において、10はメモリ本体を示し、メモリ本体10は、メモリアレイ部11、ローデコーダ12、各ビット線毎に設けられたデータラッチ回路群13、カラム選択部14、再プログラムデータ自動設定回路群15および終点検出回路16等から構成されている。

【0041】メモリアレイ11は、正規メモリアレイ11aとパリティメモリアレイ11bから構成されている。正規メモリアレイ11aにはn本(通常は512パイト程度)の正規ビット線B1~Bnが配線され、パリティメモリアレイ11bにはj本(通常は10パイト程度)のパリティビット線b1~bjが配線されている。なお、図中はワード線Wmを選択して、正規メモリセルMT1~MTnおよびパリティメモリセルmT1~mTjに対してページプログラムを行う場合を図示している。

【0042】データラッチ回路群13は、正規データラー ッチ回路SA1~SAnおよびパリティデータラッチ回 路sA1~sAjから構成され、カラム選択部14は正規カラム選択部14aおよびパリティカラム選択部14 bから構成されている。カラム選択部14はデータ転送クロック信号 ø C L に同期して作動し、正規データラッチ回路SA1~SAnおよびパリティデータラッチ回路sA1~sAjにページプログラムデータをシフト転送し、またデータラッチ回路からページデータの読み出しを行う。

【0043】再プログラムデータ自動設定回路群15は、各正規データラッチ回路SA1~SAnおよびパリティデータラッチ回路SA1~SAnおよびパリティデータラッチ回路SA1~SAnおよびパリられた自動設定回路15S-1~15S-n、15S-1~15S-jにより構成されている。自動設定回路15S-1~15S-n、15S-1~15S-jは、各プログラム動作後のベリファイ読み出し動作毎に、プログラムが終了したメモリセルの接続されたデータラッチであているデータを順次反転させて再プログラムデータを自動設定する。

【0044】終点検出回路16は、各正規データラッチ 回路SA1~SAnおよびパリティデータラッチ回路s A1~sAj毎に設けられたトランジスタT1~Tnお よびTp1~Tpj、並びにトランジスタTset、お よび反転回路INV1により構成されている。各トラン ジスタT1~TnおよびT1~T;のゲート電極がそれ ぞれの正規データラッチ回路SA1~SAnおよびパリ ティデータラッチ回路sA1~sAjの反転出力に、ソ 一ス電極が接地電位に、ドレイン電極が共通接続されて おり、プログラム未終了セルが存在して少なくとも1個 以上のデータラッチ回路の反転出力がハイレベルである 場合に、共通接続された終点検出電位Vaが接地電位と なり、反転回路INV1により終点検出信号ENDou t がハイレベルとして出力される。またトランジスタT setは、終点検出電位Vaを予めVCCレベルにプリ チャージするために設けられ、終点検出に先だってプリ チャージ信号φsetにより駆動される。

【0045】20はデータ入力部を示し、データ入力部20は、データ入力回路21とエラー検査コード発生回路22とにより構成される。データ入力回路21は正規入力データ [Din]1~nをエラー検査コード発生回路22に入力し、エラー検査コード(パリティ入力データ)[Cin]1~jを発生する。正規入力データ [Din]1~n およびエラー検査コード[Cin]1~jにより合成されるページプログラムデータは、データをは、データをしたに同期して、それぞれ正規データラッチ回路SA1~SAnおよびパリティデータラッチ回路SA1~SAnおよびパリティデータラッチ目といるよびパリティメモリセルにページプログラムされる。

【0046】30はデータ出力部を示し、データ出力部30は、エラー検査回路31とデータ訂正回路32とに

より構成される。エラー検査回路31は、ページ読み出しした正規出力データ [Dout]1 ~n およびエラー検査コード (パリティ出力データ) [Cout]1 ~j により、データ復調コード [S]1 ~j を発生する。データ訂正回路32は、正規出力データ [Dout]1 ~n およびデータ復調コード [S]1 ~j により、ページ読み出しデータ内に所定個数(たとえば1ビット)以内のエラービットが存在する場合にこれを訂正し、訂正後の正しい正規出力データ [DATA]1 ~n を出力する。

【0047】40はカウント回路(計数回路)を示し、カウント回路40は、所定回数のプログラムベリファイ回数(たとえば10回程度)を繰り返した後にプログラム未終了メモリセルが存在して終点検出できなかった場合、つまり少なくとも1個以上のデータラッチ回路の出力がローレベルである場合に、以下のようにプログラム未終了メモリセルの個数を計数する。すなわち、基本データ転送クロック信号 o C L に同期したベリファイページ読み出しデータDATAverの反転回路INV2の出カDATAverをシフト入力し、最後にチェック信号 o C H K の入力に応じてプログラム未終了メモリセルの個数を計数する。

【0048】未終了判定回路50は、メモリ本体10の反転回路INV1の出力信号 φ CHKをハイレベルで入力すると、プログラム未終了メモリセルがあるものとして、プログラム未終了メモリセルの個数の計数を開始するようにチェック信号 φ CHKをカウント回路40に出力する。

【0049】判定回路60は、カウント回路40の出力 チェック信号 φ C N T がハイレベルに切り換わったなら ば、プログラム未終了のセルが1つ以上あるものとし て、図示しない制御系に出力する。本実施形態の場合、 判定回路60は、たとえばフリップフロップにより構成 される。

【0050】図2は、図1の半導体不揮発性記憶装置におけるエラー訂正手段において、1ビットエラーに対処できる正規データビット数nとパリティデータビット数(エラー検査ビット数) jとの関係を示す図である。

【0051】エラー訂正の原理、エラー検査コード発生回路22、エラー検査回路31、およびデータ訂正回路32については、本発明の骨子と直接関係しないため、ここでは詳述しない。しかし図2によれば、512ビットの正規データビット数には10ビットのエラー検査ビット数が必要であり、したがって一般的な512ビットの正規入力データ [Din]1~nには10ビットのエラー検査コード [Cin]1~jを発生させる必要がある。

【0052】図3は、図1の半導体不揮発性記憶装置における、データプログラム時のシーケンスフローを示す図である。以下、図3のシーケンスフローについて、図

1の構成例等を参照しながら順を追って説明する。

【0053】ステップS1でデータプログラムが開始され、最初にデータ入力回路21を介して入力された正規入力データ [Din] 1 ~n に基づき、エラー検査コード発生回路22によりエラー検査コード [Cin] 1 ~ 」が発生される(ステップS2)。そして、正規入力データ [Din] 1 ~n およびエラー検査コード [Cin] 1 ~」は正規カラム選択14aおよびパリティカラム選択14bに入力され、合成したページプログラムデータがメモリアレイ内の各ピット線毎に設けられた正規データラッチ回路SA1~SAnおよびパリティデータラッチ回路SA1~SAnおよびパリティデータラッチ回路SA1~SAnおよびパリティデータラッチ回路SA1~SAnおよびパフティプS3)。

【0054】次に、図示しないプログラム制御系によりステップS4でプログラムベリファイ回数Kが0にリセットされ、プログラムパルスを印加するプログラム動作が行われ(ステップS5)、ベリファイ読み出し後に、自動設定回路15S-1~15S-n、15s-1~15s-jにおいてプログラム終了メモリセルの正規データラッチ回路SA1~SAnおよびパリティデータラッチ回路SA1~SAnおよびパリティデータラッチ回路SA1~SAj内のデータを順次反転させて再プログラムデータを自動設定するベリファイ読み出し動作(ステップS6)が連続して行われる。

【0055】次に、ステップS7で終了検出回路16および未終了判定回路50において、すべてのメモリセルのプログラムが終了したかどうかの終点検出が、再プログラムデータ内に少なくとも1個以上のプログラム未終了メモリセルに対応するデータが残っているか否かを調べることにより行われる。

【0056】その結果、全ビットプログラム終了の終点検出ができた場合には、データプログラムを完了する(ステップS12)。しかし、全ビットプログラム終了の終点検出ができなかった場合には、さらにプログラムベリファイ回数Kがインクリメントされて(ステップS8)、Kが予め設定された所定回数k0(たとえば10回程度)未満であるかどうかが調べられる(ステップS9)。そしてKがk0未満である場合には、上述したステップS5~S9のシーケンスフローが繰り返し行われ、Kがk0に到達した時点でステップS10に進む。

【0057】次にステップS10では、データラッチ回路内のデータがページ読み出しされて、プログラム未終了メモリセルの個数がカウント回路40でカウントされる。次に、ステップS11おいて、計数したプログラム未終了メモリセルの個数がエラー訂正可能な所定個数

(たとえば1個)以内であるかどうかが調べられる。その結果、プログラム未終了メモリセルの個数がエラー訂正可能な所定個数以内である場合にはデータプログラムを完了し(ステップS12)、所定個数を超えている場合にはデータプログラム失敗と判断される(ステップS13)。

【0058】以上のシーケンスフローによりデータプログラムが行われた本発明の半導体不揮発性記憶装置においては、データ読み出し時に、エラー検査回路31およびデータ訂正回路32とによりプログラム未終了メモリセルのエラー訂正がなされ、正しい正規データ [DATA] 1 ~n が読み出される。

【0059】以上説明したように、本第1の実施例に係る半導体不揮発性記憶装置によれば、所定回数のプログラム動作を繰り返し行った後にプログラム未終了メモリセルが存在しても、当該プログラム未終了メモリセルの個数がエラー訂正手段により訂正可能な所定個数以内のエラービットである場合には、プログラム未終了メモリセルを残したままデータプログラムを終了する。したがって、ごくまれに存在する非常にプログラムの遅いメモリセルに律速されることなく、高速にデータプログラムが可能となる。

### 【0060】第2実施例

図4は、本発明に係る半導体不揮発性記憶装置、たとえばNOR型フラッシュメモリの具体的な構成例を示す図である。

【0061】すなわち、図4において、100はメモリ本体を示し、メモリ本体100は、メモリアレイ部111、ローデコーダ112、各ピット線毎に設けられたデータラッチ回路群113、カラム選択部114、再プログラムデータ自動設定回路群115および終点検出回路116等から構成されている。

【0062】メモリアレイ111は、正規メモリアレイ111aとパリティメモリアレイ111bとから構成されている。正規メモリアレイ111aにはn本(通常は512バイト程度)の正規ピット線B1~Bnが配線され、パリティメモリアレイ111bにはj本(通常は10バイト程度)のパリティピット線b1~bjが配線されている。なお、図中はワード線Wmを選択して、正規メモリセルMT1~MTnおよびパリティメモリセルmT1~mTjに対してページ読み出しを行う場合を図示している。

【0063】データラッチ回路群113は、正規データラッチ回路SA1~SAnおよびパリティデータラッチ回路sA1~SAnおよびパリティデータラッチ回路sA1~SAjから構成され、カラム選択部114 は正規カラム選択部114aおよびパリティカラム選択部114bから構成されている。カラム選択部114はデータ転送クロック信号 oCLに同期して作動し、正規データラッチ回路SA1~SAnおよびパリティデータラッチ回路SA1~SAjにページプログラムデータをシフト転送し、またデータラッチ回路からワード線単位のページデータの読み出しを行う。

【0064】再プログラムデータ自動設定回路群115 は、各正規データラッチ回路SA1~SAnおよびパリ ティデータラッチ回路SA1~SAj毎に対応して設け られた自動設定回路115S-1~115S-n、11 5s-1~115s-jにより構成されている。自動設定回路115S-1~115S-n、115s-1~1 15s-jは、各プログラム動作後のベリファイ読み出し動作毎に、プログラムが終了したメモリセルの接続されたデータラッチ回路にラッチされているデータを順次反転させて再プログラムデータを自動設定する。

【0065】終点検出回路116は、各正規データラッ チ回路SA1~SAnおよびパリティデータラッチ回路 SA1~SA;毎に設けられたトランジスタT1~Tn およびTpl~Tpj、並びにトランジスタTset、 および反転回路INV100により構成されている。各 トランジスタT1~TnおよびTp1~Tpjのゲート 電極がそれぞれの正規データラッチ回路SA1~SAn およびパリティデータラッチ回路SA1~SAiの反転 出力に、ソース電極が接地電位に、ドレイン電極が共通 接続されており、消去未終了セルが存在して少なくとも 1個以上のデータラッチ回路の反転出力がハイレベルで ある場合に、共通接続された終点検出電位Vaが接地電 位となり、反転回路INV1により終点検出信号END outがハイレベルとして出力される。またトランジス タTsetは、終点検出電位Vaを予めVCCレベルに プリチャージするために設けられ、終点検出に先だって プリチャージ信号φsetにより駆動される。

【0066】120はデータ入力部を示し、データ入力部120は、データ入力回路121とエラー検査コード発生回路122により構成される。データ入力回路121は正規入力データ [Din]1~nをエラー検査コード(パリティ入力データ) [Cin]1~jを発生する。正規入力データ [Din]1~nおよびエラー検査コード [Cin]1~jにより合成されるワード線単位のページにすった。データ転送クロック信号のCLに同期して、それぞれ正規データラッチ回路SA1~SA1にシフト転送され、対応する正規メモリセルおよびパリティメモリセルに順次データプログラムされる。

【0067】130はデータ出力部を示し、データ出力部130は、エラー検査回路131とデータ訂正回路132とにより構成される。エラー検査回路131は、ページ読み出しした正規出力データ [Dout]1~n およびエラー検査コード (パリティ出力データ) [Cout]1~jを発生する。データ訂正回路132は、正規出力データ [Dout]1~nおよびデータ復調コード [S]1~jにより、ページ読み出しデータ復調コード [S]1~jにより、ページ読み出しデータ内に所定個数(たとえば1ビット)以内のエラービットが存在する場合にこれを訂正し、訂正後の正しい正規出力データ [DATA]1~nを出力する。

【0068】140はカウント回路(計数回路)を示し、カウント回路140は、所定回数の消去ベリファイ

回数(たとえば10回〜数10回程度)を繰り返した後に消去ブロック内の各ページ内に消去未終了メモリセルが存在して終点検出できなかった場合、つまり各ページ毎のベリファイ読み出し時に1個以上のデータラッチ回路の出力がハイレベルである場合に、以下のように消去未終了メモリセルの個数を計数する。すなわち、基本データ転送クロック信号 Φ C L に同期したベリファイページ読み出しデータ D A T A v e r をシフト入力し、最後にチェック信号 Φ C H K の入力に応じて消去未終了メモリセルの個数を計数する。

【0069】未終了判定回路150は、メモリ本体100の反転回路1NV100の出力信号 Φ C H K をハイレベルで入力すると、消去未終了メモリセルがあるものとして、消去未終了メモリセルの個数の計数を開始するようにチェック信号 Φ C H K をカウント回路140に出力する。

【0070】判定回路160は、カウント回路140の出力チェック信号 ØCNTがハイレベルに切り換わったならば、消去未終了のセルが1つ以上あるものとして、図示しない制御系に出力する。本実施例の場合も、判定回路160は、たとえばフリップフロップにより構成される。

【0071】図4の半導体不揮発性記憶装置におけるエラー訂正手段において、1ビットエラーに対処できる正規データビット数nとパリティデータビット数(エラー検査ビット数) j との関係は、第1実施例の場合と同様に、図2に示すような関係である。

【0072】エラー訂正の原理、エラー検査コード発生回路122、エラー検査回路131、およびデータ訂正回路132については、本発明の骨子と直接関係しないため、ここでは詳述しない。しかし図2によれば、512ビットの正規データビット数には10ビットのエラー検査ビット数が必要である。したがって、ワード線を512バイトページサイズとして128ページの64Kバイトデ消去ブロック単位が構成されている場合、各ページ毎で、512バイトの正規入力データ[Din]1~nには10ビットのエラー検査コード[Cin]1~jを発生させる必要がある。

【0073】図5は、図4の半導体不揮発性記憶装置においてデータの書き換えを行う場合データ消去時のシーケンスフローを示す図である。また、図6は、その後のデータプログラム時のシーケンスフローを示す図である。以下、図5および図6のシーケンスフローについて、図4の構成例等を参照しながら順を追って説明する。

【0074】まず、図5のデータ消去時のシーケスフローについて説明する。ステップS21でデータ消去が開始され、ステップS22で消去ベリファイ回数Kを最初の1に設定して消去パルスを印加する消去動作(ステップS23)、およびベリファイ読み出し動作(ステップ

S24)が連続して行われる。ステップS24のベリファイ読み出し動作の結果、ブロック内のすべてのメモリセルの消去終了の終点検出ができた場合には(ステップS25)、データ消去を完了する。

【0075】一方、ステップS24のベリファイ読み出し動作の結果、ブロック内のすべてのメモリセルの消去終了の終点検出ができなかった場合には(ステップS25)、ステップS26において、消去ベリファイ回数K0 (たとえば100~1000程度)未満であるか否かが調べられる。その結果、消去ベリファイ回数Kが設定回数K0未満である場合には、さらに消去ベリファイ回数Kが設定回数K0未満リファイのシーケンスフローが繰り返し行われる。そして、消去ベリファイ回数Kが設定回数K0に到達した時点で消去未終了メモリセルが存在するものとしてステップS28の処理に移行する。

【0076】ステップS28において、消去ブロック内のページ番地Pg-NOをまず最初の1に設定して、データラッチ回路の消去データをページ読み出しして、消去未終了メモリセルの個数がカウントされる(ステップS29)。

【0077】次に、ステップS30で、計数した消去未終了メモリセルの個数がエラー訂正可能ま所定個数(たとえば1個)以内であるか否かが調べられる。その結果、消去未終了メモリセルの個数がエラー訂正可能な所を超えてる場合にはデータ消去失敗と判断される(ステップS34)。一方、消去未終了メモリセルの個数がエラー訂正可能な所定個数以内である場合には、ページ番地Pg-NOが最終アドレス番地であるかといる。そして、ページ番地Pg-NOが最終アドレス番地でない場合には、さらアップS32)、上述したステップS29~S32のシーケータコンスフローが繰り返し行われる。そした、ページ番地Pg-NOが最終ページ番地に到達した時点で、データ消去完了と判断される(ステップS33)。

【0078】次に、図6のデータプログラム時のシーケンスフローについて説明する。データの消去が完了した場合、(図3のステップS33)には、引き続いてデータプログラムが開始される(ステップS101)。まず、ステップS102でブロック内のページ番地PgーNOをまず最初の1に設定して、当該ページの正規入力データ [Din] 1~nに基づき、エラー検査コード発生回路22によりエラー検査コード [Cin] 1~jが発生される(ステッS103)。次に、当該ページ内でメモリセルのアドレス番地PgーNOを最初の1に対で、メモリセルのアドレス番地PgーNOを最初の1に対じてデータ内容に応じてデータプログラムが行われ(ステップS105)、アドレス番地Ar-NOが最終アドレス番

地であるか否かが調べられる(ステップS106)。その結果、アドレス番地Ar-NOが最終アドレス番地でない場合には、さらにアドレス番地Ar-NOがインクリメントされて(ステップS107)、上述したステップS103~S107のシーケンスフローが繰り返し行われる。そして、アドレス番地Ar-NOが最終アドレス番地に到達した時点で当該ページのデータプログラムが完了する。

【0079】次に、ステップS108でページ番地Pg-NOが最終番地であるか否かが調べられる。その結果、アドレス番地Pg-NOが最終番地でない場合には、さらにページ番地Pg-NOがインクリメントされて(ステップS109)、上述したステップS103~S109のシーケンスフローが繰り返し行われる。そして、アドレス番地Ar-NOが最終アドレス番地に到達した時点で当該ページのデータプログラムが完了する(S110)。

【0080】以上のシーケンスフローによりデータの書き換えが行われた本発明の半導体不揮発性記憶装置においては、データ読み出し時に、エラー検査回路31およびデータ訂正回路32とにより消去未終了メモリセルのエラー訂正がなされ、正しい正規データ [DATA] 1~n が読み出される。

【0081】以上説明したように、本第2の実施例に係る半導体不揮発性記憶装置によれば、所定回数の消去動作を繰り返し行った後に消去未終了メモリセルが存在しても、当該消去未終了メモリセルの個数がエラー訂正可能な所定個数以内のエラービットである場合には、消去未終了メモリセルを残したままデータプログラムを行う。したがって、ごくまれに存在する非常に消去の遅いメモリセルに律速されることなく、高速にデータプログラムが可能となり、ひいては、データの書き換えを高速に行うことができる。さらには、消去の速いメモリセルが過剰消去されることを防止でき、信頼性の高い半導体不揮発性記憶装置を実現することができる。

#### [0082]

【発明の効果】以上説明したように、本発明によれば、 高速にデータプログラムを行うこができる半導体不揮発 性記憶装置を実現することができる。

【0083】また、本発明によれば、データ消去を高速に行うことができ、データの書き換えを高速に行うことが可能で、さらには過剰消去メモリセルの発生を防止でき、信頼性の向上を図れる半導体不揮発性記憶装置を実現することができる。

#### 【図面の簡単な説明】

【図1】本発明に係る半導体不揮発性記憶装置の第1の 実施例の構成例を示す図である。

【図2】図1の半導体不揮発性記憶装置におけるエラー 訂正手段において、1ビットエラーに対処できる正規デ ータビット数 n とパリティデータビット数 (エラー検査 ビット数) j との関係を示す図である。

【図3】図1の半導体不揮発性記憶装置における、データプログラム時のシーケンスフローを示す図である。

【図4】本発明に係る半導体不揮発性記憶装置の第2の 実施例の構成例を示す図である。

【図5】図1の半導体不揮発性記憶装置における、データ消去時のシーケンスフローを示す図である。

【図6】図1の半導体不揮発性記憶装置における、データプログラム時のシーケンスフローを示す図である。

【図7】NAND型およびDINOR型フラッシュメモリにおける、メモリアレイ構造を示す図である。

【図8】一般的なNOR型フラッシュメモリにおける、 メモリアレイ構造およびデータ消去時のバイアス条件を 示す図である。

【図9】従来のワード線セクタを単位としたページプログラムを行う半導体不揮発性記憶装置のメモリセル間のプログラム速度の差を示す図である。

【図10】従来のワード線セクタを単位としたページプログラムを行う半導体不揮発性記憶装置における、データプログラム時のシーケンスフローを示す図である。

【図11】消去ブロック内のメモリセル間の消去速度の 差を示す図である。

【図12】従来のNOR型フラッシュメモリにおけるデータ書き換え時のシーケンスフローを示す図である。 【符号の説明】

B1~Bn…正規ビット線、b1~bj…パリティビッ ト線、Wm…選択ワード線、MT1~MTn…正規メモ リセル、mT1~mTj…パリティメモリセル、SA1 ~SAn…正規データラッチ回路、sA1~sAi…パ リティデータラッチ回路、 [Din]1 ~n …正規入力 データ、 [Dout] 1 ~n …正規出力データ、 [DA TA] 1 ~n …エラー訂正後の正規出力データ、 [Ci n] 1 ~j …入力エラー検査コード、 [Cout] 1 ~ j …出力エラー検査コード、[S]1 ~j …データ復調 コード、DATAver…ベリファイページ読み出しデ ータ、φCL…データ転送クロック信号、φcheck …チェック信号、φset…プリチャージ信号、END out…終点検出信号、Va…終点検出電位、INV1 ~ INV2, INV100…反転回路、10, 100… メモリ本体、11,1111メモリアレイ部、11a, 111a…正規メモリアレイ、11b, 111b…パリ ティメモリアレイ、12,112…ローデコーダ、1 3, 113…データラッチ回路、14, 114…カラム 選択部、14a, 114a…正規カラム選択部、14 b, 114b…パリティカラム選択部、15, 115… 再プログラムデータ自動設定回路、16,116…終点 検出回路、20,120…データ入力部、21,121 …データ入力回路、22,122…エラー検査コード発 生回路、30,130…データ出力部、31,131…

エラー検査回路、32,132…データ訂正回路、4 0, 140…カウント回路、50, 150…未終了判定

回路、60, 160…判定回路。

【図1】

正規データビット数 n 8 16 32 64 128 256 512 1024 エラー検査ビット数) 5 7 6 10 11

t prog(プログラム時間)

【図2】





MTI ベリファイ読み出し SF6 MT2 全ピットプログラム 終了の終点検出? -WL3 WL2 vss NO мтзіі WL4 WL3 K=K+1 YES MT4 ST2| | K < K0? SL2 WL4 NO SF10 SF9 SBL FAIL PASS

(b)

(a)

【図8】



【図11】



【図12】



# フロントページの続き

(72) 発明者 内貴 唯八

東京都品川区北品川6丁目7番35号 ソニ 一株式会社内